package com.ruoyi.sale.domain;

import java.math.BigDecimal;
import java.time.LocalDateTime;
import java.util.Date;
import java.util.List;

import com.baomidou.mybatisplus.annotation.TableField;
import com.fasterxml.jackson.annotation.JsonFormat;
import com.ruoyi.common.core.domain.BaseEntity;
import lombok.Data;
import lombok.Getter;
import lombok.Setter;
import lombok.ToString;
import org.apache.commons.lang3.builder.ToStringBuilder;
import org.apache.commons.lang3.builder.ToStringStyle;
import com.ruoyi.common.annotation.Excel;

/**
 * 销售订单对象 t_sale_order
 * 
 * @author ruoyi
 * @date 2024-10-28
 */
@ToString
@Setter
@Getter
public class SaleOrder extends BaseEntity
{
    private static final long serialVersionUID = 1L;

    /** 编号 */
    private Long id;

    /** 销售订单号 */
    @Excel(name = "销售订单号")
    private String orderNo;

    /** 销售状态（0未发布，1已提交，2未审批，3审批通过，4审批驳回，5生产中，6已生产，7未质检，8已质检，9出库中，10已出库，11发货中，12已发货，13退换货，14确认收货、15未打款、16部分打款、17已结清） */
    @Excel(name = "销售状态", readConverterExp = "0=未发布，1已提交，2未审批，3审批通过，4审批驳回，5生产中，6已生产，7未质检，8已质检，9出库中，10已出库，11发货中，12已发货，13退换货，14确认收货、15未打款、16部分打款、17已结清")
    private Long status;

    /** 客户 id */
    @Excel(name = "客户 id")
    private Long customerId;

    /** 客户（公司）名称 */
    private String customerName;

    /** 联系人 */
    private String contactPerson;

    /** 销售员 id */
    @Excel(name = "销售员 id")
    private Long saleUserId;

    /** 合计数量 */
    @Excel(name = "合计数量")
    private Long number;

    /** 最终合计价格,单位:元 */
    @Excel(name = "最终合计价格,单位:元")
    private BigDecimal totalPrice;

    /** 合计产品价格,单位:元 */
    @Excel(name = "合计产品价格,单位:元")
    private BigDecimal totalProductPrice;

    /** 已收款金额,单位:元 */
    @Excel(name = "已收款金额,单位:元")
    private BigDecimal receiptPrice;

    /** 优惠率,百分比 */
    @Excel(name = "优惠率,百分比")
    private BigDecimal discountPercent;

    /** 优惠金额,单位:元 */
    @Excel(name = "优惠金额,单位:元")
    private BigDecimal discountPrice;

    /** 其它金额,单位:元 */
    @Excel(name = "其它金额,单位:元")
    private BigDecimal otherPrice;

    /** 创建人 */
    @Excel(name = "创建人")
    private String createBy;

    //创建人姓名
    private String createName;

    /** 创建时间 */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @Excel(name = "下单时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
    private Date createTime;

    /** 修改人 */
    @Excel(name = "修改人")
    private String updateBy;

    //修改人姓名
    private String updateName;

    /** 修改时间 */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @Excel(name = "修改时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
    private Date updateTime;

    /** 是否删除 */
    private Long deleted;

    /** 订单产品 */
    @TableField(exist = false)
    List<SaleOrderProduct> goodsList;


}
